草庐IT

ios - RubyMotion 和指针

全部标签

c++ - 单一所有者和多个引用的智能指针

回到过去,我使用原始指针实现链表和树。当我尝试使用智能指针实现时,我遇到了以下问题,因为我不知道如何使用只有一个所有者但有0个或多个引用的指针:举一个二叉树的例子:对于初学者来说,节点应该是指针的唯一“所有者”:节点与树一起生死,所以对我来说,让它们成为unique_ptr是有意义的而不是shared_ptr:classTree{std::unique_ptrroot_;}classNode{std::unique_ptrleft_child_,right_child_;}然后我不得不做一个这样的算法:Node*node=root_.get();//left_countright_co

c++ - 使用未知指针类型调用函数重载

所以,我有一个基类PhysicsObject,子类Colliding,以及再次从中派生的两个类,Static和Newtonian.检查碰撞时,我将所有碰撞写入std::vector>collisionVector.(碰撞检测是相当基础的,它并不是问题的真正一部分。)现在,在检测到所有碰撞后,我遍历collisionVector并调用静态collide方法,它具有以下四个重载:voidcollide(Newtonian*first,Newtonian*second);voidcollide(Newtonian*object,Static*obstacle);inlinevoidcolli

c++ - 以下哪一项是 "auto"推导指针类型的更正确方法?

关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭8年前。Improvethisquestion(非常基本的问题:)我发现以下两种方式都生成int*类型。我可以知道哪个更合适吗?inti=42;autoa=&i;auto*b=&i;(我试图将指针示例与引用示例相关联:autoc=i;和auto&d=i;。但似乎类比在这里不起作用.)编辑:我还发现另一个(密切相关的)例子很奇怪:autoi=42,p=&i;//failsatcompilationautoi=42,*p=&i;//pas

C++ - 通过单个指针访问多个对象的接口(interface)

我需要存储一个对象指针容器。这些对象有一些我想要强制执行(可能在编译时)和使用的通用方法/属性(接口(interface))。示例:structA{voidfly(){}};structB{voidfly(){}};Aa;Bb;std::vectorobjects;objects.push_back(&a);objects.push_back(&b);for(auto&el:objects)el->fly();更简单的解决方案是A和B继承一个共同的基类,如FlyingClass:structFlyingClass{voidfly(){}};structA:publicFlyingCla

算法打卡day03|链表专题01:虚拟头节点使用、单链表查找删除元素、链表设计通过索引(add、delete、get)、使用双指针思路实现链表反转|Leetcode203、707、206

1.基础知识——链表是由指针串联在一起的线性结构分类:(1)单链表:每个节点由数据域与指针域组成{data,next}(2)双链表:每个节点由数据域及指针域(两个指针)组成{data,pre,next}(3)循环链表:节点结构与单链表一致,但是首尾相连存储:内存分布不是连续的链表定义代码※链表优点在于长度不固定,能够实现动态增删,适用于增删频繁但是查询频率比较低的情景Leetcode203.移除链表元素题目链接:https://leetcode.cn/problems/remove-linked-list-elements/description/分析:经典链表操作,主要需要考虑两种场景当前节

C语言——深入理解指针(3)

今天搞const修饰指针,呼,终于睡醒早了一会。搞起来搞起来        今天搞const修饰指针,我们已经知道,把一个变量的地址交给一个指针的时候,可以通过指针来修改变量的值,那如果我们用const来修饰变量或者指针的话,会发生什么呢?1.const修饰变量 首先我们看没有const修饰的情况#includeintmain(){ inta=10; a=100; printf("%d",a); return0;}首先我们初始化a,然后将a赋值为100,然后打印a,看a的值, 显然a的值发生了改变,这小孩都会 下面我们用constint来看一下 intmain(){ constinta=10;

c++ - 指向数组声明的指针

考虑以下情况:1.externint*a;int*a=newint(1);//OK2.externinta[];inta[5];//Ok3.externint(*a)[];int(*a)[5];//error:redefinitionof'a'withadifferenttype:'int(*)[5]'vs'int(*)[]'您能解释一下为什么第3种情况会抛出编译时错误吗?与前两者究竟有何不同?我正在寻找对标准的相应引用。 最佳答案 简而言之:第三种情况不同,因为指针变量的type不匹配-extern声明了一个指向具有未知大小(不完

python - 将 Cython 融合类型转换为 C++ 指针

这是一个关于从Cython融合类型转换为C++类型的一般性问题,我将用一个最小的例子来描述。考虑肤浅的C++函数模板:templatevoidscale_impl(constT*x,T*y,constTa,constsize_tN){for(size_tn=0;n我希望能够在任何numpyndarray上调用这个函数任何类型和形状。使用Cython,我们首先声明函数模板:cdefextern:voidscale_impl[T](constT*x,T*y,constTa,constsize_tN)然后声明我们希望操作的有效标量类型:ctypedeffusedScalar:floatdou

c++ - 一个 "strong"迭代器指针/引用

是否存在“强”迭代器之类的东西。我的意思是一个迭代器坚持它引用的值而不是它所在的地址,这样如果值被交换到不同的地址,迭代器将继续指向这个新地址中的它;不管它在数据结构中被移动到哪里? 最佳答案 是也不是。但为什么?你想要什么std::iter_swap(strong_a,strong_b);做什么?正如KarolyHorvath指出的那样,您可以实现自己的容器,它有自己的迭代器(迭代器只是一个概念,不是任何一种类型)。至于“实现一个可以很好地与标准库一起工作”的方法,这取决于您想到的是标准库的哪一部分。您不能向容器中添加东西(除非您

c++ - 如何将数据类型的 std::map 制作为函数指针

我有这样的数据结构enumDataType_t{INT,FLOAT};structData{DataType_Ttype;void*min;void*max;};变量min和max取决于type的值。我想知道是否有办法创建std::map之类的std::mapmyMap;myMap[INT]=??//Hereshouldbeapointertoafunctionlikeint(*FcnPtr)(Datad,boolmin);myMap[FLOAT]=??//Hereshouldbeapointertoafunctionlikefloat(*FcnPtr)(Datad,boolmin);